Locking এবং Deadlock Management

Database Tutorials - টি-এসকিউএল (T-SQL) - Transactions এবং Locking
464

Locking এবং Deadlock Management ডেটাবেস পরিচালনার গুরুত্বপূর্ণ বিষয়। Locking ডেটা অ্যাক্সেসের সিঙ্ক্রোনাইজেশন নিশ্চিত করার জন্য ব্যবহৃত হয়, এবং Deadlock Management একাধিক ট্রানজ্যাকশনের মধ্যে সৃষ্ট deadlock অবস্থা থেকে বের হওয়ার জন্য ব্যবহৃত হয়।

নিচে Locking এবং Deadlock Management এর ব্যবহারের বিস্তারিত ব্যাখ্যা দেওয়া হলো।


Locking

Locking এমন একটি প্রক্রিয়া যার মাধ্যমে SQL Server বা অন্য কোন ডেটাবেস সিস্টেম ডেটা অ্যাক্সেসে প্রতিযোগিতা নিয়ন্ত্রণ করে। যখন একাধিক ট্রানজেকশন একই ডেটাতে কাজ করে, তখন ডেটার অ্যাক্সেস সঠিকভাবে নিয়ন্ত্রণ করা প্রয়োজন, যাতে ডেটার অখণ্ডতা (integrity) বজায় থাকে।

Locking এর প্রকারভেদ:

  1. Shared Lock (S Lock):
    • যখন একটি ট্রানজেকশন ডেটা পড়ার জন্য লক নেয়, অন্য ট্রানজেকশনগুলি ঐ ডেটাতে শুধুমাত্র পড়ার কাজ করতে পারে, কিন্তু লিখতে পারে না।
    • উদাহরণ: একটি SELECT অপারেশন।
  2. Exclusive Lock (X Lock):
    • যখন একটি ট্রানজেকশন ডেটা পরিবর্তন করার জন্য লক নেয়, তখন অন্য কোনো ট্রানজেকশন ঐ ডেটা পড়া বা লেখা করতে পারবে না।
    • উদাহরণ: একটি INSERT, UPDATE, বা DELETE অপারেশন।
  3. Update Lock (U Lock):
    • এটি একটি মাঝারি ধরনের লক যা বিশেষভাবে UPDATE স্টেটমেন্টের জন্য ব্যবহৃত হয়। যখন একটি ট্রানজেকশন কোনও রেকর্ড আপডেট করার পরিকল্পনা করে, তখন একটি U Lock নেওয়া হয়। অন্য কোনো ট্রানজেকশন ঐ রেকর্ডে পরিবর্তন করতে পারে না, তবে অন্য কিছু পড়তে পারে।
  4. Intent Lock (IS, IX, SIX):
    • যখন একটি ট্রানজেকশন একটি নির্দিষ্ট রেকর্ডে লক নেবে, কিন্তু সার্বিক টেবিল বা ডেটাবেসে লক নিতে চায় না, তখন এই ধরনের লক ব্যবহৃত হয়।

Locking এর মাধ্যমে সমস্যার সমাধান:

Locking ব্যবস্থার মাধ্যমে Dirty Reads, Non-repeatable Reads, এবং Phantom Reads এড়ানো যায়।

  • Dirty Read: এক ট্রানজেকশন একটি ডেটা আপডেট করলে অন্য ট্রানজেকশন যদি ঐ ডেটা পড়ে তবে সেটি একটি অনির্ভরযোগ্য ডেটা হতে পারে।
  • Non-repeatable Read: যদি একটি ট্রানজেকশন একটি রেকর্ড পড়ে এবং পরবর্তী সময়ে আবার ঐ রেকর্ডটি পড়ে, কিন্তু প্রথমবারের মান পরিবর্তিত হয়ে যায়।
  • Phantom Read: একটি ট্রানজেকশন একটি ডেটাসেট পড়তে পারে, কিন্তু অন্য ট্রানজেকশন ডেটা যোগ বা মুছে ফেললে পরবর্তী বার সেই ডেটাসেট আর একই থাকে না।

Deadlock Management

Deadlock একটি পরিস্থিতি, যেখানে দুটি বা তার বেশি ট্রানজেকশন একে অপরের জন্য লক ধরে রেখে থাকে এবং তারা একে অপরকে সম্পূর্ণ করতে পারছে না, কারণ প্রতিটি ট্রানজেকশন অন্য একটি ট্রানজেকশনের সম্পন্ন হওয়ার জন্য অপেক্ষা করছে।

Deadlock এর উদাহরণ:

ধরা যাক, দুটি ট্রানজেকশন একই সময় দুটি টেবিল লক করার চেষ্টা করছে:

  • ট্রানজেকশন A টেবিল 1 লক করে এবং টেবিল 2 লক করার জন্য অপেক্ষা করছে।
  • ট্রানজেকশন B টেবিল 2 লক করে এবং টেবিল 1 লক করার জন্য অপেক্ষা করছে।

এটি deadlock তৈরি করে, কারণ দুটি ট্রানজেকশনই পরস্পরকে অপেক্ষা করতে বাধ্য করছে, এবং কোনো ট্রানজেকশনই শেষ হতে পারছে না।

Deadlock Management এর পদ্ধতি:

  1. SQL Server Deadlock Detection: SQL Server নিজেই deadlock সনাক্ত করে এবং স্বয়ংক্রিয়ভাবে এক ট্রানজেকশনকে ROLLBACK করে দেয়, যার ফলে অন্য ট্রানজেকশনটি সম্পন্ন হতে পারে। যখন SQL Server deadlock সনাক্ত করে, তখন এটি Deadlock Victim চিহ্নিত করে এবং তাকে ROLLBACK করে দেয়।
  2. Deadlock Graph: SQL Server একটি deadlock graph তৈরি করে, যাতে deadlock এর কারণ চিহ্নিত করা যায়। এই গ্রাফের মাধ্যমে বুঝতে পারা যায় কোন ট্রানজেকশনগুলি deadlock তৈরি করছে এবং কেন।

Deadlock Avoidance Strategies:

  • Lock Ordering: সমস্ত ট্রানজেকশনগুলির জন্য একটি নির্দিষ্ট লক অর্ডার নির্ধারণ করা যেতে পারে। অর্থাৎ, সব ট্রানজেকশনগুলো একটি নির্দিষ্ট ক্রমে টেবিল বা রেকর্ডে লক নিবে, যাতে deadlock না হয়।
  • Smaller Transactions: বড় ট্রানজেকশনকে ছোট ছোট ট্রানজেকশনে ভাগ করা। এতে একাধিক ট্রানজেকশন একযোগে কাজ করতে পারে এবং deadlock হওয়া কমে যায়।
  • Retry Logic: যখন একটি ট্রানজেকশন deadlock এ পড়ে, তখন retry logic ব্যবহার করা হয়। অর্থাৎ, যে ট্রানজেকশনটি rollback হয়েছে, তা আবার চেষ্টা করবে।

Deadlock Avoidance Example:

BEGIN TRANSACTION;

-- Transaction A
UPDATE Table1 SET Column1 = 'Value1' WHERE ID = 1;
WAITFOR DELAY '00:00:05'; -- Simulate some work

-- Transaction B
BEGIN TRANSACTION;
UPDATE Table2 SET Column2 = 'Value2' WHERE ID = 2;
WAITFOR DELAY '00:00:05'; -- Simulate some work
COMMIT;

এটি একটি সিম্পল deadlock সৃষ্টির উদাহরণ, যেখানে ট্রানজেকশন A এবং B পরস্পরের সাথে deadlock তৈরি করবে যদি তাদের মধ্যে লক ব্যবস্থা না থাকে।


Deadlock Detection and Handling in SQL Server

SQL Server deadlock সনাক্ত করে এবং স্বয়ংক্রিয়ভাবে তাকে ম্যানেজ করে। SQL Server Profiler বা Extended Events ব্যবহার করে deadlock logs দেখতে পারেন এবং deadlock কেন ঘটছে তা বিশ্লেষণ করতে পারেন।

Deadlock Trace:

SQL Server একটি ডেডলক লোগ তৈরি করে যা পরবর্তীতে বিশ্লেষণ করা যায়:

DBCC TRACEON(1204, -1);  -- Enable deadlock trace
DBCC TRACEOFF(1204, -1); -- Disable deadlock trace

এটি SQL Server এর লগে deadlock ঘটার তথ্য তৈরি করে, যা পরবর্তীতে বিশ্লেষণ করা যায়।


সারাংশ

  • Locking: এটি ডেটাবেসের টেবিল এবং রেকর্ডে একাধিক ট্রানজেকশনের অ্যাক্সেস নিয়ন্ত্রণ করে। Shared, Exclusive, Update, এবং Intent লক ধরনের ব্যবহৃত হয়।
  • Deadlock: এটি তখন ঘটে যখন একাধিক ট্রানজেকশন একে অপরের জন্য অপেক্ষা করে এবং কোনো একটি ট্রানজেকশনও সম্পন্ন হয় না।
  • Deadlock Management: SQL Server স্বয়ংক্রিয়ভাবে deadlock সনাক্ত করে এবং একটি ট্রানজেকশন ROLLBACK করে দেয়। deadlock এড়াতে lock ordering, smaller transactions, এবং retry logic ব্যবহার করা যায়।

Deadlock এবং Locking এর সঠিক ব্যবস্থাপনা ডেটাবেসের পারফরম্যান্স এবং অখণ্ডতা বজায় রাখতে অত্যন্ত গুরুত্বপূর্ণ।

Content added By
Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...